package com.itheima.quicksort;

public class QuickSortDemo {
    public static void main(String[] args) {
        /*
            1. 从右开始找比基准数小的
            2. 从左开始找比基准数大的
            3. 交换两个值的位置
            4. 红色继续往左找，蓝色继续往右找，知道两个箭头指向同一个索引位置
            5. 基准数归位
         */
        int[] arr = {6, 1, 2, 7, 9, 3, 4, 5, 10, 8};

        quickSort(arr, 0, arr.length - 1);

        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
        System.out.println();
    }

    private static void quickSort(int[] arr, int left, int right) {
        if (right < left) {
            return;
        }
        int left0 = left;
        int right0  = right;

        // 计算基准数
        int baseNum = arr[left0];
        while (left != right) {
            while (arr[right] >= baseNum && right > left) {
                right--;
            }
            while ((arr[left] <= baseNum && left < right)) {
                left++;
            }
            int temp = arr[left];
            arr[left] = arr[right];
            arr[right] = temp;
        }
        int temp = arr[left];
        arr[left] = arr[left0];
        arr[left0] = temp;
        
        quickSort(arr, left0, left -1);
        quickSort(arr, left +1, right0 );
    }
}
